package org.dromara.system.service;

import org.dromara.system.domain.bo.TotalPlanBo;
import org.dromara.system.domain.vo.AppProcurementPlanVo;
import org.dromara.system.domain.bo.AppProcurementPlanBo;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.system.domain.vo.TotalPlanVo;

import java.util.Collection;
import java.util.List;

/**
 * 采购计划Service接口
 *
 * @author Lion Li
 * @date 2025-09-12
 */
public interface IAppProcurementPlanService {

    /**
     * 查询采购计划
     *
     * @param id 主键
     * @return 采购计划
     */
    AppProcurementPlanVo queryById(Long id);

    /**
     * 分页查询采购计划列表
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 采购计划分页列表
     */
    TableDataInfo<AppProcurementPlanVo> queryPageList(AppProcurementPlanBo bo, PageQuery pageQuery);

    /**
     * 查询符合条件的采购计划列表
     *
     * @param bo 查询条件
     * @return 采购计划列表
     */
    List<AppProcurementPlanVo> queryList(AppProcurementPlanBo bo);

    /**
     * 新增采购计划
     *
     * @param bo 采购计划
     * @return 是否新增成功
     */
    String insertByBo(AppProcurementPlanBo bo);

    /**
     * 修改采购计划
     *
     * @param bo 采购计划
     * @return 是否修改成功
     */
    Boolean updateByBo(AppProcurementPlanBo bo);

    /**
     * 校验并批量删除采购计划信息
     *
     * @param ids     待删除的主键集合
     * @param isValid 是否进行有效性校验
     * @return 是否删除成功
     */
    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);

    TotalPlanVo total(TotalPlanBo totalPlanBo);
}
